package com.huike.web.controller.review;


import com.huike.common.core.controller.BaseController;
import com.huike.common.core.domain.AjaxResult;
import com.huike.review.pojo.Review;
import com.huike.review.service.ReviewService;
import com.mysql.cj.x.protobuf.MysqlxDatatypes;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Update;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

/**
 * 该Controller主要是为了复习三层架构以及Mybatis使用的，该部分接口已经放开权限，可以直接访问
 * 同学们在此处编写接口通过浏览器访问看是否能完成最简单的增删改查
 */
@RestController
@RequestMapping("/review")
public class MybatisReviewController extends BaseController {

    @Autowired
    private ReviewService reviewService;

    /**=========================================================新增数据============================================*/

    @PostMapping("/saveData/{name}/{age}/{sex}")
    public AjaxResult save(@PathVariable String name,@PathVariable String age,@PathVariable String sex) {
        int save = reviewService.save(name, age, sex);
        if(save!=0){
            return AjaxResult.success("新增成功");
        }
        else {
            return AjaxResult.error("新增失败");
        }
    }
    /**=========================================================删除数据=============================================*/
    @DeleteMapping("/remove/{id}")
    public AjaxResult delete(@PathVariable Long id) {
        int delete = reviewService.delete(id);
        if(delete!=0){
            return AjaxResult.success("删除成功");
        }
        else {
            return AjaxResult.error("删除失败");
        }
    }


    /**=========================================================修改数据=============================================*/
@PutMapping("/update")
    public AjaxResult update(@RequestBody Review review) {
    int update = reviewService.update(review);
    if(update!=0){
            return AjaxResult.success("修改成功");
        }
        else {
            return AjaxResult.error("修改失败");
        }
    }





    /**=========================================================查询数据=============================================*/
@GetMapping("/getById")
    public AjaxResult getOne(@Param("id") Long id) {
        Review one = reviewService.getOne(id);
       return AjaxResult.success(one);
    }


    @GetMapping("/getDataByPage")
    public AjaxResult page(@Param("pageNum") int pageNum,@Param("pageSize") int pageSize) {


        List<Review> page = reviewService.page(pageNum, pageSize);
        return AjaxResult.success(page);

    }



}